#pragma once

#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
#include<assert.h>

typedef struct BinaryTreeNode* QDataType;

typedef struct QNode
{
	QDataType data;
	struct QNode* next;
}QNode;

typedef struct Queue
{
	QNode* head;
	QNode* tail;
	int size;
}Queue;

void QInit(Queue* q);

void QDestroy(Queue* q);

bool QEmpty(Queue* q);

int QSize(Queue* q);

void QPush(Queue* q,QDataType x);

void QPop(Queue* q);

QDataType QFront(Queue* q);

QDataType QBack(Queue* q);
